# $Id$
# Maintainer: Qurban Ullah <qurbanullah@avouch.org>
# Contributor: Qurban Ullah <qurbanullah@avouch.org>

pkgbase=systemd
pkgname=('systemd' 'libsystemd' 'systemd-sysvcompat')
pkgver=234
pkgrel=1
arch=('i686' 'x86_64')
url="http://www.freedesktop.org/wiki/Software/systemd"
makedepends=('acl' 'cryptsetup' 'docbook-xsl' 'gperf' 'lz4' 'xz' 'pam' 'libelf'
             'intltool' 'iptables' 'kmod' 'libcap' 'libidn' 'libgcrypt'
             'libmicrohttpd' 'libxslt' 'util-linux' 'linux-api-headers'
             'python-lxml' 'quota-tools' 'shadow' 'gnu-efi-libs' 'git')
options=('strip' 'debug')
source=("git://github.com/systemd/systemd.git#tag=v$pkgver"
        'avouch.conf'
        'loader.conf'
        'splash-avouch.bmp')
md5sums=('SKIP'
         '90ea67a7bb237502094914622a39e281'
         '976c5511b6493715e381f43f16cdb151'
         '1b3aa3a0551b08af9305d33f85b5c2fc'
         '20ead378f5d6df4b2a3e670301510a7d'
         'ddaef54f68f6c86c6c07835fc668f62a'
         '1e2f9a8b0fa32022bf0a8f39123e5f4e')

getsrc() {
	cd ${srcdir}	
	git clone --depth 1 --branch v$pkgver git://github.com/systemd/systemd.git
}

pkgver() {
	cd "${srcdir}/${pkgbase}"
	#cd "${srcdir}/${pkgbase}-${pkgver}"
	echo "$(git describe --tags)" | sed -e 's|v||g'
}

prepare() {
	cd "${srcdir}/${pkgbase}"
	#cd "${srcdir}/${pkgbase}-${pkgver}"
	patch -Np1 -i ../0998-resolved-create-etc-resolv.conf-symlink-at-runtime.patch
	./autogen.sh
}

build() {
	cd "${srcdir}/${pkgbase}"
	#cd "${srcdir}/${pkgbase}-${pkgver}"

	local timeservers=({0..3}.avouch.pool.ntp.org)

	./configure \
	--libexecdir=/usr/lib \
	--localstatedir=/var \
	--sysconfdir=/etc \
	--enable-lz4 \
	--enable-gnuefi \
	--disable-ima \
	--disable-apparmor \
	--disable-seccomp \
	--with-sysvinit-path= \
	--with-sysvrcnd-path= \
	--with-default-dnssec=no \
	--with-default-hierarchy=hybrid \
	--with-dbuspolicydir=/usr/share/dbus-1/system.d \
	--with-rpmmacrosdir=no \
	--without-kill-user-processes \
	--with-ntp-servers="${timeservers[*]}"
	make
}

package_systemd() {

  pkgdesc="system and service manager"
  license=('GPL2' 'LGPL2.1')
  depends=('acl' 'bash' 'dbus' 'iptables' 'kbd' 'kmod' 'hwids' 'libcap'
           'libgcrypt' 'libsystemd' 'libidn' 'lz4' 'pam' 'libelf' 'libseccomp'
           'util-linux' 'xz')
  provides=('nss-myhostname' "systemd-tools=$pkgver" "udev=$pkgver")
  replaces=('nss-myhostname' 'systemd-tools' 'udev')
  conflicts=('nss-myhostname' 'systemd-tools' 'udev')
  optdepends=('cryptsetup: required for encrypted block devices'
              'libmicrohttpd: remote journald capabilities'
              'quota-tools: kernel-level quota management'
              'systemd-sysvcompat: symlink package to provide sysvinit binaries'
              'polkit: allow administration as unprivileged user')
  backup=(etc/dbus-1/system.d/org.freedesktop.systemd1.conf
          etc/dbus-1/system.d/org.freedesktop.hostname1.conf
          etc/dbus-1/system.d/org.freedesktop.login1.conf
          etc/dbus-1/system.d/org.freedesktop.locale1.conf
          etc/dbus-1/system.d/org.freedesktop.machine1.conf
          etc/dbus-1/system.d/org.freedesktop.timedate1.conf
          etc/dbus-1/system.d/org.freedesktop.import1.conf
          etc/dbus-1/system.d/org.freedesktop.network1.conf
          etc/pam.d/systemd-user
          etc/systemd/bootchart.conf
          etc/systemd/coredump.conf
          etc/systemd/journald.conf
          etc/systemd/journal-remote.conf
          etc/systemd/journal-upload.conf
          etc/systemd/logind.conf
          etc/systemd/system.conf
          etc/systemd/timesyncd.conf
          etc/systemd/resolved.conf
          etc/systemd/user.conf
          etc/udev/udev.conf)
  install="systemd.install"

	cd "${srcdir}/${pkgbase}"
	#cd "${srcdir}/${pkgbase}-${pkgver}"

	make DESTDIR="$pkgdir" install

	# get rid of RPM macros
	rm -r "$pkgdir/usr/lib/rpm"

	# add back tmpfiles.d/legacy.conf
	install -m644 "tmpfiles.d/legacy.conf" "$pkgdir/usr/lib/tmpfiles.d"

	# Replace dialout/tape/cdrom group in rules with uucp/storage/optical group
	sed -i 's#GROUP="dialout"#GROUP="uucp"#g;
	s#GROUP="tape"#GROUP="storage"#g;
	s#GROUP="cdrom"#GROUP="optical"#g' "$pkgdir"/usr/lib/udev/rules.d/*.rules

	sed -i 's/dialout/uucp/g;
	s/tape/storage/g;
	s/cdrom/optical/g' "$pkgdir"/usr/lib/sysusers.d/basic.conf

	# ensure proper permissions for /var/log/journal. This is only to placate
	chown root:systemd-journal "$pkgdir/var/log/journal"
	chmod 2755 "$pkgdir/var/log/journal"

	# match directory owner/group and mode from extra/polkit
	chown root:70 "$pkgdir"/usr/share/polkit-1/rules.d
	chmod 0750     "$pkgdir"/usr/share/polkit-1/rules.d

	# overwrite the systemd-user PAM configuration with our own
	install -Dm644 $srcdir/systemd-user.pam "$pkgdir/etc/pam.d/systemd-user"

	# add example bootctl configuration
	install -Dm644 "$srcdir/avouch.conf" "$pkgdir"/usr/share/systemd/bootctl/avouch.conf
	install -Dm644 "$srcdir/loader.conf" "$pkgdir"/usr/share/systemd/bootctl/loader.conf
	install -Dm644 "$srcdir/splash-avouch.bmp" "$pkgdir"/usr/share/systemd/bootctl/splash-avouch.bmp

	sed -i 's/L+/#/' $pkgdir/usr/lib/tmpfiles.d/etc.conf

	install -m 0644 "$srcdir"/sysctl.conf.README $pkgdir/etc/sysctl.conf
	ln -s ../sysctl.conf $pkgdir/etc/sysctl.d/99-sysctl.conf

	# Install Avouch default preset policy
	mkdir -p  $pkgdir/usr/lib/systemd/system-preset/
	mkdir -p  $pkgdir/usr/lib/systemd/user-preset/
	install -m 0644 $srcdir/90-default.preset $pkgdir/usr/lib/systemd/system-preset/
	
	# ship default policy to leave services disabled
	install -m 0644 $srcdir/99-default-disable.preset $pkgdir/usr/lib/systemd/system-preset/
	install -m 0644 $srcdir/85-display-manager.preset $pkgdir/usr/lib/systemd/system-preset/

	mkdir -vp $pkgdir/usr/lib/firewalld/services/
	install -Dm0644 $srcdir/systemd-journal-remote.xml $pkgdir/usr/lib/firewalld/services/
	install -Dm0644 $srcdir/systemd-journal-gatewayd.xml $pkgdir/usr/lib/firewalld/services/

	# Make sure directories in /var exist
	mkdir -p $pkgdir/var/lib/systemd/coredump
	mkdir -p $pkgdir/var/lib/systemd/catalog
	mkdir -p $pkgdir/var/lib/systemd/backlight
	mkdir -p $pkgdir/var/lib/systemd/rfkill
	mkdir -p $pkgdir/var/log/journal
	touch $pkgdir/etc/udev/hwdb.bin
	touch $pkgdir/var/lib/systemd/catalog/database
	touch $pkgdir/var/lib/systemd/random-seed
	touch $pkgdir/var/lib/systemd/clock

	### manpages shipped with systemd-sysvcompat
	rm "$pkgdir"/usr/share/man/man8/{telinit,halt,reboot,poweroff,runlevel,shutdown}.8

	### runtime libraries shipped with libsystemd
	rm "$pkgdir"/usr/lib/lib{nss,systemd,udev}*.so*
	  
	# include MIT license, since it's technically custom
	install -Dm644 "$srcdir/$pkgname-$pkgver/LICENSE.LGPL2.1" \
	"$pkgdir/usr/share/licenses/systemd/LICENSE"

}

package_libsystemd() {
  pkgdesc="systemd client libraries"
  depends=('glibc' 'libcap' 'libgcrypt' 'lz4' 'xz')
  license=('GPL2')
  provides=('libsystemd.so' 'libudev.so')
  
  	cd "${srcdir}/${pkgbase}"
	#cd "${srcdir}/${pkgbase}-${pkgver}"

	make DESTDIR="$pkgdir" install-rootlibLTLIBRARIES
}

package_systemd-sysvcompat() {
	pkgdesc="sysvinit compat for systemd"
	license=('GPL2')
	groups=('base')
	conflicts=('sysvinit')
	depends=('systemd')
	
	cd "${srcdir}/${pkgbase}"
	#cd "${srcdir}/${pkgbase}-${pkgver}"

	install -dm755 "$pkgdir"/usr/share/man/man8
	cp -d --no-preserve=ownership,timestamp \
	man/{telinit,halt,reboot,poweroff,runlevel,shutdown}.8 \
	"$pkgdir"/usr/share/man/man8

	install -dm755 "$pkgdir/usr/bin"
	for tool in runlevel reboot shutdown poweroff halt telinit; do
		ln -s 'systemctl' "$pkgdir/usr/bin/$tool"
	done

	ln -s '../lib/systemd/systemd' "$pkgdir/usr/bin/init"
}
